_ Ни=Ыоая и Комсоае — единство и. 
борьба прот 7/77 : 


Сергей Нуралиев, ис 


Вы можете использовать 
Гомисоае-подход в ваших 
проектах! 


“Мы говорим именно про подход, а не про готовые 
продукты / технологии 


(нь) ННЕоаа"" 


Зачем нужен Ёомисоае-подход? 


. Повысить скорость создания приложений 
. Снизить стоимость 
. [|онизить сложность владения 


. Защита от проблем при смене команды 
разработчиков 


(но) ННЕоаа"" 


Н!=Ноаа & 1оммсоае 
Разные вселенные? 


В своем докладе покажу: 
. Это не так 
. Когда это не так 
. Зачем это не так 


(нь) ННГоаа"* 


«Большой» Гомисоае 
Часто думают, что (о\м/соае — это для маленьких задач 


Но существует | о\м/соае для крупных проектов и для 
облаков 


Такого Го\мусоае в мире немного 


(но) ННГоаа"* 


Г омисоае используют (пока?) 
не везде 


В ЕБР и СКМ такой подход встречается 


(нь) ННГоаа"* 


Когда ом/соае-подход нужен? 
» Много прикладной функциональности 
. Много (десятки, сотни) разработчиков 


» Хочется получить бонусы от Гом/соае-подхода 


(нь) ННГоаа"* 


Как совместить (ом/соае и 
Н'!=2Ноаа? 


У нас такой опыт есть — постараемся поделиться! 


(нь) ННГоаа"* 


Немного о нас 


Платформа 1С:Предприятие - Го\/соде-платформа для 
быстрой разработки различных бизнес-приложений 


Она включает все (!), что нужно для этих задач 


(нь) ННЕоаа"" 


Клиенты хотели «больше» 


Клиентам нравился наш подход и наше решение 
Но они росли 

-> нашим технологиям нужно было расти вместе с ними 
Крупные клиенты тоже начали использовать наши приложения 


-> и стали требовать от нас «соответствовать» 


(нь) ННГоаа"* 


Рост нагрузки на платформу 


Сопсиггепе Озег$ 


Сейчас -— 2022г. 
8000 > 10.000 пользователей 


Начало — 2003г. 
80 пользователей 


2003 2022 


—®— СопситепЕ Узег$ 


(но) НЕЕНГоаа** 


Как мы дошли до такой жизни? © 


Итог: постоянный рост требований по 
масштабируемости 


Сейчас уже речь о самых крупных компаниях в РФ 


-> нужна последовательная и постоянная борьба за 
НэНоаа 


(но) ННЕоаа"" 


Амбициозная цель 


У нас: 
. Достичь Н!!оаа, не отходя от Цомусоае 


. |0о\м/соде нам терять нельзя — наша основная 
ценность 


У вас может быть и наоборот: 
. Получить [о\м/сосе, не отходя от Н!Шоаа 


(но) ННГоаа"* 


Может, разделить? 


Нам часто предлагали: сделайте отдельную платформу для КОРП 
— мы не стали 


Нам важно сохранять парадигму [1о\/соае - и в общем, и в 
деталях 


Крайне нежелательно усложнять модель разработки 


Платформа должна брать на себя максимум возможного 


(но) ННГоаа"* 


Идеал не всегда достижим 


Не все задачи Не !оаа можно решить без усложнения 
разработки 


Иногда не получится скрыть природу вещей, т.к. они 
влияют на логику работы 


Покажу на примерах 


Но нужно стараться! 


(но) ННЕоаа"" 


НЕМНОГО ПРИМЕРОВ 


(нь) ННЕоаа"" 


оаа Баапст> 


В бизнес-приложениях нагрузка очень неравномерная 


Вызов от вызова по нагрузке может отличаться на 
порядки 


По СРЦИ, Т/О, ОВМ5$, дисковой подсистеме 


(нь) ННГоаа"* 


Любимая задача на 
собеседованиях 


«Спроектируйте балансировщик нагоузки» 


Обычно рассказывают про Коипта-Корг, но вот в 
бизнес-приложениях он совсем плох ® 


А потом предлагают «пометить тяжелые 
запросы» 


Но унас омсоае 


(но) ННЕоаа"" 


Еан! со[егапсе 


Например, автоматический перезапуск рабочих 
процессов 


Пользователи не должны ничего заметить! 


Но это забота и о разработчиках! 


Они плохо написали - а пользователи ничего не 
заметят! 


Быстоо поднятое не считается угтавшим 


(нь) ННГоаа"" 


Управляемые блокировки 
Сначала использовали блокировки ОВМ5, отказались: 


Нормально только на «небольших» / маленьких 
«средних» проектах 


Иногда прямо безобразие - те же эскалации! 


Потом сделали свое 


А потом сделали свое заново® 


(нь) ННЕоаа"" 


Наш механизм блокировок 


Н=Ноаа-сервис кластера 
. Определение пересечений и помещение в ожидание 
е Отслеживание аеа юосКов 


Параллельность всегда, кроме случаев с требованиями по 
бизнес-логике 


Как раз тот случай, когда нельзя скрывать природу вещей! 
Но и тут Гом/соаде -— управлять блокировками очень просто 


Но можно и нужно думать головой о бизнес-логике © 


(нь) ННГоаа"" 


Дата-акселератор (т-тетогу ОВ) 


Содепате: Нта В 


У заказчиков растут потребности в Аналитике 
* Надо обрабатывать млн. записей за доли секунды 
° «Живой анализ» не терпит задержек и ожиданий 


Сделали свою т-тетогу ОВ 
» «Очень реляционная» 


Выдерживаем [о\/соде (даже «ГегоСоае»): 
. Не требуется никаких усилий разработчиков -— она просто 


работает 
* Полная совместимость с другими ОВМ$ В 
(Не) Ннисаа" 


Механизм копий баз данных 


Автоматическое распараллеливание читающей 
нагрузки 


По сути — горизонтальное масштабирование ОВМ$ 
Борьба за скорость заливки и синхронизации данных 


Тоже Гом/соае - от разработчика ничего не требуется 


(нь) ННЕоаа"" 


тонкий 
меБ-клиент 
клиент 
Мобильные 
клиенты 


Клиент 


Кластер серверов 1С 


Сервер = 1. 1< ©. ©. ©. © т 
БФ и Ф] ео] ео) ео] [65-0] [е--Ф] [еиз-6] 
Отчеты Отчеты Отчеты 
СУБ = =@® Дата- =@ Дата- <® Дата- 
д а я акселератор ==] акселератор == акселератор 


Механизм копий БД 


НЕ) НЕНГоаЯ"" 


Аеще... 


. Хранилище бинарных данных 

. Хранилище сеансовых данных 

* Механизм ограничений ресурсов 

. Миграция данных 

Решение систем линейных уравнений 

° Кэширование 

. Журнал регистрации со специальными индексами 

. Фоновые задания, регламентные задания 

. Многопоточность — чтобы не было опасно и сложно! 


(нь) ННЕоаа"" 


Приемы и опыт Еом/соае для 
Н!=оаа 


(нь) ННЕоаа"" 


Высокоуровневая модель 


Слой абстракции 
. Работы с данными 
. С пользовательским интерфейсом 
. [Г]равами 


Позволяет проводить оптимизации, не меняя 
приложение 


(нь) ННЕоаа"" 


Высокоуровневая модель 
1 ом/соае — это про уровень абстракции 
Помогает реализовать ВОО 


Обеспечивает семантику предметной области и 
декларативный подход при разработке бизнес- 
приложений 


(но) ННЕоаа"" 


Делаем о\мисоае-слой 


Плохая новость: часть приемов оптимизации становится 
недоступна 


Хорошая новость: вы можете оптимизировать движок 
[омсоае-слоя 


Сами приложения менять не потребуется 


(нь) ННЕоаа"" 


Не «ковыряйте дырочек» 


[ом/соае-слой храните максимально целостным 
И не ведитесь на уговоры ® 
Иначе случится плохое... 


(нь) ННЕоаа"" 


Н!'=Ноаа тоже бывает разный 
В бизнес-приложениях бывает: 

. КОР/] 

. Облачный 


У них разные профили нагрузки 


Это нужно учитывать и в концепции 1 о\м/соае 


(нь) ННГоаа"* 


[ом/ — не только соае 


Помимо простой разработки, нужно и простое 
администрирование 


Красивого названия не придумали, мы иногда называем 
«хего-администрирование» 


В примерах выше речь шла не только о разработчиках, 
но и об администраторах! 


(но) ННГоаа"" 


Безопасность! 


Закладывайте в модель вопросы безопасности 
И это именно про 1омсоае 


Это «защита» и от разработчика, и от пользователя 


(нь) ННЕоаа"" 


Не экономьте на инструментах 


Мониторинг, Ылогирование, диагностика и т.д. 


(нь) ННЕоаа"" 


Не упускайте бонус! 
Доработали под капотом Цом/соде-платформу — 
все приложения на ней ощутили результат 


Это дорогого стоит! 


(нь) ННЕоаа"" 


Что ещё нам предстоит 
довести до ума 


. Очередь заданий со сложной балансировкой 
. Скорость работы встроенного языка 
. Ком/ (е\уе| зесигку 


(нь) ННЕоаа"" 


Цифры 


Строк в Платформе 1С 
» более 16 млн 


Строк в 1С:ЕКР 
» более 12 млн 


е если бы без Гом/соае, 
то $0 —- 50 млн 


Разработчиков на платформе 1С 
. более 500 000 


Количество пользователей 
. до 15О ООО АРМ 
* до ТО ООО конкурентных 


Объёмы данных 


. десятки ТБ 
(знаем проектс 56 ТБ) 


(но) ННГоаа"* 


Примеры из жизни... 


э 


ТРАНСМАШХОЛАИНГ 


г 
С - 


Ростех 


Почта России. 150 ООО рабочих мест. 86 филиалов и1ООО структурных 
подразделений. 


Трансмашхолдинг. 40 ООО автоматизированных рабочих мест. ЕКР, МЕЗ, 
СРМ, \/М5$, ЕСМ, НЕМ, ТТТЕ. Есть предприятия с более 5000 
зарегистрированными пользователями ЕКР. 


Государственная корпорация «Ростех». 50 ООО пользователей. 
Централизованная система управления финансами и закупками 700 
организаций. Ежедневно онлайн /ООО пользователей. 56 ТБ данных. 


(нь) ННГоаа"* 


Й] раоратная связь 
| и комментарии по 
`докледу по ссылке 


) 


Спасибо! 


/ не На вь 


\ 2022 


